<template>
	<view class="login-container">
		<!-- 提示登录的图标 -->
		<uni-icons type="contact-filled" size="100" color="#AFAFAF"></uni-icons>
		<!-- 登录按钮 -->
		<u-button type="primary" shape="circle" class="btn-login" :ripple="true" ripple-bg-color="#909399"
			@click="getUserInfo">一键登录</u-button>
		<!-- 登录提示 -->
		<view class="tips-text">登录后尽享更多权益</view>
	</view>
</template>

<script>
	// 1. 按需导入 mapMutations 辅助函数
	import {
		mapMutations,
		mapState
	} from 'vuex'
	export default {
		name: "my-login",
		data() {
			return {

			};
		},
		computed: {
			// 调用 mapState 辅助方法，把 m_user 模块中的数据映射到当前用组件中使用
			...mapState('m_user', ['redirectInfo']),
		},
		methods: {
			// 2. 调用 mapMutations 辅助方法，把 m_user 模块中的 updateUserInfo 映射到当前组件中使用
			...mapMutations('m_user', ['updateUserInfo', 'updateToken', 'updateRedirectInfo']),
			// 获取微信用户的基本信息
			async getUserInfo() {
				let [userErr, userResult] = await uni.getUserProfile({
					desc: '用于完善会员资料'
				}).catch(userErr => userErr)
				console.log(userResult);

				// 判断是否获取用户信息成功
				if (userErr || !userResult.errMsg === "getUserProfile:ok") return uni.showToast({
					title: '您取消了登录授权！',
					duration: 1500,
					icon: 'none'
				})

				// 获取用户信息成功， e.detail.userInfo 就是用户的基本信息
				console.log(userResult.userInfo)

				// 3. 将用户的基本信息存储到 vuex 中
				this.updateUserInfo(userResult.userInfo)

				// 获取登录成功后的 Token 字符串
				this.getToken(userResult)
			},
			async getToken(info) {
				// 调用微信登录接口
				const [err, res] = await uni.login().catch(err => err)
				// 判断是否 uni.login() 调用失败
				if (err || res.errMsg !== 'login:ok') return uni.showToast({
					title: '登录失败！',
					duration: 1500,
					icon: 'none'
				})

				console.log(res);

				// 准备参数对象
				// const query = {
				// 	code: res.code,
				// 	encryptedData: info.encryptedData,
				// 	iv: info.iv,
				// 	rawData: info.rawData,
				// 	signature: info.signature
				// }

				// 访问后端api 换取 token
				const token = await uniCloud.callFunction({
					name: 'getToken',
					data: {
						code: res.code
					}
				})
				if (token.result.code !== 0) return uni.showToast({
					title: 'fail',
					duration: 1500,
					icon: 'none'
				})
				uni.showToast({
					title: 'success',
					duration: 1500,
					icon: 'none'
				})


				// 2. 更新 vuex 中的 token
				this.updateToken(token.result.token)

				// 判断 vuex 中的 redirectInfo 是否为 null
				// 如果不为 null，则登录成功之后，需要重新导航到对应的页面
				this.navigateBack()
			},
			// 返回登录之前的页面
			navigateBack() {
				// redirectInfo 不为 null，并且导航方式为 switchTab
				if (this.redirectInfo && this.redirectInfo.openType === 'switchTab') {
					// 调用小程序提供的 uni.switchTab() API 进行页面的导航
					uni.switchTab({
						// 要导航到的页面地址
						url: this.redirectInfo.from,
						// 导航成功之后，把 vuex 中的 redirectInfo 对象重置为 null
						complete: () => {
							this.updateRedirectInfo(null)
						}
					})
				}
			}
		}
	}
</script>

<style lang="scss">
	page {
		width: 750rpx;
		height: 100vh;
	}

	.login-container {
		// 登录盒子的样式
		height: 750rpx;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		background-color: #f8f8f8;
		position: relative;
		overflow: hidden;

		&:first-child {
			position: relative;


			// 绘制登录盒子底部的半椭圆造型
			&:after {
				content: ' ';
				display: block;
				position: absolute;
				width: 750rpx;
				height: 150rpx;
				left: 0;
				bottom: 0;
				background-color: white;
				border-radius: 100%;
				transform: translateY(50%);
			}
		}


		// 登录按钮的样式
		.btn-login {
			width: 90%;
			border-radius: 100px;
			margin: 15px 0;
			background-color: #A68E64;
		}

		// 按钮下方提示消息的样式
		.tips-text {
			font-size: 12px;
			color: gray;
		}
	}
</style>
